/**
 * Copyright (c) 2013, Redsolution LTD. All rights reserved.
 * 
 * This file is part of Xabber project; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License, Version 3.
 * 
 * Xabber is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License,
 * along with this program. If not, see http://www.gnu.org/licenses/.
 */
package com.digitalbuana.smiles.xmpp;

import org.xmlpull.v1.XmlPullParser;

/**
 * Provide common interface to populate java object from received xml.
 * 
 * @author alexander.ivanov
 * 
 * @param <T>
 */
public abstract class AbstractInflater<T extends Instance> {

	/**
	 * Updates instance from tag name or attributes.
	 * 
	 * Parser position mustn't be changed.
	 * 
	 * @param instance
	 * @param parser
	 * @return modified instance.
	 */
	protected T preProcess(XmlPullParser parser, T instance) {
		return instance;
	}

	/**
	 * Called when packet have been fully parsed.
	 * 
	 * Parser position mustn't be changed.
	 * 
	 * @param instance
	 * @return modified instance.
	 */
	protected T postProcess(T instance) throws Exception {
		return instance;
	}

	/**
	 * Parses inner tag.
	 * 
	 * Parser position either <b>must</b> be move to the end of processed tag,
	 * either <b>mustn't</b> be changed at all.
	 * 
	 * @param parser
	 * @param instance
	 * @return Whether parser position have been changed.
	 * @throws Exception
	 */
	protected boolean parseInner(XmlPullParser parser, T instance)
			throws Exception {
		return false;
	}

	/**
	 * Parse XML tag and populate element instance. At the beginning of the
	 * method call, the XML parser will be positioned on the opening tag. At the
	 * end of the method call, the parser <b>must</b> be positioned on the end
	 * of processed tag.
	 * 
	 * @param parser
	 *            an XML parser.
	 * @param instance
	 *            instance to be updated.
	 * @return updated or replaced instance.
	 * @throws Exception
	 *             if an error occurs parsing the XML.
	 */
	public T parseTag(XmlPullParser parser, T instance) throws Exception {
		String name = parser.getName();
		instance = preProcess(parser, instance);
		while (true) {
			int eventType = parser.next();
			if (eventType == XmlPullParser.START_TAG) {
				if (!parseInner(parser, instance))
					ProviderUtils.skipTag(parser);
			} else if (eventType == XmlPullParser.END_TAG) {
				if (name.equals(parser.getName()))
					break;
				else
					throw new IllegalStateException();
			} else if (eventType == XmlPullParser.END_DOCUMENT)
				break;
		}
		return postProcess(instance);
	}

}
